<template>
    <div class="add-card">
      <header class="add-header">
        <el-page-header content="增加月卡" @back="$router.back()" />
      </header>
  
      <main class="add-main">
        <div class="form-container">
          <div class="title">车辆信息</div>
  
          <div class="form">
            <el-form
              ref="carInfoForm"
              :model="carInfoForm"
              :rules="carInfoRules"
              label-width="100px"
            >
              <el-form-item label="车主姓名" prop="personName">
                <el-input v-model="carInfoForm.personName" />
              </el-form-item>
  
              <el-form-item label="联系方式" prop="phoneNumber">
                <el-input v-model="carInfoForm.phoneNumber" />
              </el-form-item>
  
              <el-form-item label="车辆号码" prop="carNumber">
                <el-input v-model="carInfoForm.carNumber" />
              </el-form-item>
  
              <el-form-item label="车辆品牌" prop="carBrand">
                <el-input v-model="carInfoForm.carBrand" />
              </el-form-item>
            </el-form>
          </div>
        </div>
  
        <div class="form-container">
          <div class="title">最新一次月卡缴费信息</div>
  
          <div class="form">
            <el-form
              ref="feeForm"
              :model="feeForm"
              :rules="feeFormRules"
              label-width="100px"
            >
              <el-form-item label="有效日期" prop="payTime">
                <el-date-picker
                  v-model="feeForm.payTime"
                  type="daterange"
                  range-separator="至"
                  start-placeholder="开始日期"
                  end-placeholder="结束日期"
                  value-format="yyyy-MM-dd"
                />
              </el-form-item>
  
              <el-form-item label="支付金额" prop="paymentAmount">
                <el-input v-model="feeForm.paymentAmount" />
              </el-form-item>
  
              <el-form-item label="支付方式" prop="paymentMethod">
                <el-select v-model="feeForm.paymentMethod">
                  <el-option
                    v-for="item in payMethodList"
                    :key="item.id"
                    :value="item.id"
                    :label="item.name"
                  />
                </el-select>
              </el-form-item>
            </el-form>
          </div>
        </div>
      </main>
  
      <footer class="add-footer">
        <div class="btn-container">
          <el-button @click="resetForm">重置</el-button>
  
          <el-button type="primary" @click="confirmAdd">确定</el-button>
        </div>
      </footer>
    </div>
  </template>
  
  <script>
  import { createCardAPI, getCardDetailAPI } from "@/api/card";
  export default {
    name: "CardAdd",
  
    data() {
      return {
        carInfoForm: {
          personName: "",
          phoneNumber: "",
          carNumber: "",
          carBrand: "",
        },
        //校验
        carInfoRules: {
          personName: [
            {
              required: true,
              message: "请输入车主姓名",
              trigger: "blur",
            },
          ],
          phoneNumber: [
            {
              required: true,
              message: "请输入联系方式",
              trigger: "blur",
            },
            //正则校验
            {
              pattern: /^1[3-9]\d{9}$/,
              message: "请输入正确的手机号",
              trigger: "blur",
            },
          ],
          carNumber: [
            {
              required: true,
              message: "请输入车辆号码",
              trigger: "blur",
            },
            //自定义校验 validator
            {
              validator: this.validatorCarNumber,
              trigger: "blur",
            },
          ],
          carBrand: [
            {
              required: true,
              message: "请输入车辆品牌",
              trigger: "blur",
            },
          ],
        },
        feeForm: {
          payTime: [], // 支付时间
          paymentAmount: "", // 支付金额
          paymentMethod: "", // 支付方式
        },
        //缴费校验
        feeFormRules: {
          payTime: [
            {
              required: true,
              message: "请选择支付时间",
            },
          ],
          paymentAmount: [
            {
              required: true,
              message: "请输入支付金额",
              trigger: "blur",
            },
          ],
          paymentMethod: [
            {
              required: true,
              message: "请选择支付方式",
              trigger: "change",
            },
          ],
        },
  
        // 支付方式列表
        payMethodList: [
          {
            id: "Alipay",
            name: "支付宝",
          },
          {
            id: "WeChat",
            name: "微信",
          },
          {
            id: "Cash",
            name: "线下",
          },
        ],
      };
    },
    computed: {
      id() {
        return this.$route.query.id;
      },
    },
    created() {
      if (this.id) {
        this.getCardDetail();
      }
    },
    methods: {
      async getCardDetail() {
        try {
          const { data } = await getCardDetailAPI(this.id);
          console.log(data);
          //车辆信息赋值
          const { personName, phoneNumber, carNumber, carBrand } = data;
          this.carInfoForm = { personName, phoneNumber, carNumber, carBrand };
          //支付信息赋值
          const { cardStartDate, cardEndDate, paymentAmount, paymentMethod } = data;
          this.feeForm = {
            payTime: [cardStartDate, cardEndDate],
            paymentAmount,
            paymentMethod,
          };
        } catch (error) {
          console.error("获取卡片详情失败:", error);
        }
      },
      // 重置表单
      resetForm() {
        this.$refs.feeForm.resetFields();
        this.$refs.carInfoForm.resetFields();
      },
      // 自定义车牌号校验器
      validatorCarNumber(rule, value, callback) {
        const plateNumberRegex = /^[\u4E00-\u9FA5][\da-zA-Z]{6}$/;
        if (plateNumberRegex.test(value)) {
          callback();
        } else {
          callback(new Error("请输入正确的车牌号"));
        }
      },
      //点击确定按钮
      confirmAdd() {
        this.$refs.carInfoForm.validate((valid) => {
          if (!valid) return;
          this.$refs.feeForm.validate(async (valid) => {
            if (!valid) return;
            //把上边量对象中的数据合并到下边这个对象中
            const payload = {
              ...this.feeForm,
              ...this.carInfoForm,
              //单独处理时间
              cardStartDate: this.feeForm.payTime[0],
              cardEndDate: this.feeForm.payTime[1],
            };
            // 删掉多余字段
            // console.log(payload);
            //因为接口做了校验，多字段不行，所以提交之前把多余的字段删掉
            delete payload.payTime;
            await createCardAPI(payload);
            this.$router.back();
          });
        });
      },
    },
  };
  </script>
  
  <style scoped lang="scss">
  .add-card {
    background-color: #f4f6f8;
    height: 100vh;
  
    .add-header {
      display: flex;
      align-items: center;
      padding: 0 20px;
      height: 64px;
      background-color: #fff;
  
      .left {
        span {
          margin-right: 4px;
        }
  
        .arrow {
          cursor: pointer;
        }
      }
  
      .right {
        text-align: right;
      }
    }
  
    .add-main {
      background: #f4f6f8;
      padding: 20px 130px;
  
      .form-container {
        background-color: #fff;
  
        .title {
          height: 60px;
          line-height: 60px;
          padding-left: 20px;
        }
  
        .form {
          margin-bottom: 20px;
          padding: 20px 65px 24px;
  
          .el-form {
            display: flex;
            flex-wrap: wrap;
  
            .el-form-item {
              width: 50%;
            }
          }
        }
      }
  
      .preview {
        img {
          width: 100px;
        }
      }
    }
  
    .add-footer {
      position: fixed;
      bottom: 0;
      width: 100%;
      padding: 24px 50px;
      color: #000000d9;
      font-size: 14px;
      background: #fff;
      text-align: center;
    }
  }
  </style>